三种不同函数原型求mxn阶矩阵的转置矩阵

        分别按如下函数原型编程计算并输出mxn阶矩阵的转置矩阵。其中,m和n的值由用户从键盘输入。已知m和n的值都不超过10。

  •         void Transpose(int a[][N],int at[][M],int m,int n);
  •         void Transpose(int (*a)[N],int (*at)[M],int m,int n);
  •         void Transpose(int *a,int *at,int m,int n);

        心得体会都在注释里了_(:з)_

#include<stdio.h>
#define M 10
#define N 10
//void Transpose(int a[][N],int at[][M],int m,int n);//第一种方法,数组
//void Transpose(int (*a)[N],int (*at)[M],int m,int n);//第二种方法,行指针
void Transpose(int *a,int *at,int m,int n);//第三种方法,列指针
int main(void)
{
    int a[M][N];//一定要写明最多为10x10矩阵,不然就像我半天不知道错在哪了qwq
    int at[N][M];
    int n,m;
    printf("Input m:");
    scanf("%d",&m);
    printf("Input n:");
    scanf("%d",&n);
    printf("Input mxn matrix:\n");
    for(int i=0;i<m;i++)
    {
        for(int j=0;j<n;j++)
            scanf("%d",&a[i][j]);
    }
    Transpose(*a,*at,m,n);//如果使用第三种列指针的方法,传参时必须写出*a、*at,其他两种写a即可
    return 0;
}
//第一种方法,向函数传递数组
/*void Transpose(int a[][N],int at[][M],int m,int n)
{
    int i,j;
    printf("转置后的矩阵:\n");
    for(i=0;i<n;i++)//先循环n,后循环m
    {
        for(j=0;j<m;j++)
        {
            at[i][j] = a[j][i];//转置矩阵的行等于原矩阵的列
            printf("%d ",at[i][j]);
        }
        printf("\n");
    }
}*/
//第二种方法,函数形参为行指针
/*void Transpose(int (*a)[N],int (*at)[M],int m,int n)
{
    int i,j;
    printf("转置后的矩阵:\n");
    for(i=0;i<n;i++)//先循环n,后循环m
    {
        for(j=0;j<m;j++)
        {
            *(*(at+i)+j) = a[j][i];
            printf("%d ",*(*(at+i)+j));//等价于at[j][i]
        }
        printf("\n");
    }
}*/
//第三种方法,函数形参为列指针
void Transpose(int *a,int *at,int m,int n)
{
    int i,j;
    printf("转置后的矩阵:\n");
    for(i=0;i<n;i++)//先循环n,再循环m
    {
        for(j=0;j<m;j++)
        {
            at[i*M+j] = a[j*N+i];
            printf("%d ",at[i*M+j]);//不能等价于at[i][j],而且必须是i*M,不能是I*m
        }
        printf("\n");
    }
}

参考输入输出1,m>n

参考输入输出2,m<n

  • 4
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值